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(54) Digital communications switching fabric 

(57) A type of switching fabric for exchanging vari- 
able-size frames of digital information between frame 
processors coupled directly or indirectly to one or more 
digital communication lines. It comprises one or more 
multi-line serial communication controllers (MSCCs) : 
and a backplane providing a full mesh of serial point-to- 
point bi-directional links between each MSCC, and, in a 
loopback, from each MSCC back to itself. The MSCCs 
collectively manage the transfer of variable-size frames 
between the frame processors. To transfer digital infor- 
mation from a source line to a destination line, a frame 
processor coupled to the ingress line drives the switch- 
ing fabric by signaling its MSCC that there is information. 
The ingress MSCC then switches the digital information 
through the backplane to the MSCC serving the frame 
processor coupled to the egress line. The switching fab- 
ric uses a clocking scheme that makes possible high 
throughput rates. 








: \ Frame ; r" 


; | Processor j j RA M [ 









Processor 



N Ceil Interconnect Gateway 
! [(9f$l.9*&. 



^2, 



' - - I i 

^Switching Fabric _ J| | 



Fig. 1 



Printed by Jouve. 75001 PARIS (FR) 



(Cont. next page) 



EP 0 844 763 A2 



(Reference for clocking backplane signals) 25 



16- 

Interrupt Signal 
"(to Frame Processor) 



Send/ Receive 
Control 
Signals 



31 Interrupt 
Conditions 




Interrupt 
^Register 
/ data 



Configuration 
Registers 



T 



33-- 



\ 




Local Bus | 
Controller 




Configuration 

information -J 
R/W by PICs 



Configuration 
Information R/W 
by Frame 
Processors 



Multi-line Serial Communication Controller (MSCC) 



-25a (Reference for clocking local bus signals) 



Buffers & BDs to and 
from on -card RAM 



Fig. 3 



1 



EP 0 844 763 A2 



2 



Description 

TECHNICAL FIELD 

The present invention pertains to the field of digital 
communication controllers. More particularly, this inven- 
tion relates to a broadband switching fabric for switch- 
ing, between digital communication lines, variable-size 
frames of digital information. 

BACKGROUND OF THE INVENTION 

A digital switch system routes digital information 
from an incoming digital communication line to an out- 
going digital communication line. As the term is used 
here, digital communication line means a bi-directional 
connection that may be one physical wire for each di- 
rection of digital information flow, or one wire that is 
sometimes used for one direction and sometimes used 
for the other. A switch typically consists of a chassis with 
slots to accommodate a number of access cards, each 
usually connected to several of the digital communica- 
tion lines serviced by the switch. (A high-speed line, 
such as a 45 Mbps DS-3, may be connected to a card 
by itself.) 

A switching fabric, as the term is used here, is a part 
of the switch that moves the digital information to and 
from the random access memory (RAM) of line proces- 
sors connected directly to the digital communication 
lines. There can be more than one switching fabric in a 
switch, and there can be different types of switching fab- 
rics for moving different types of digital information. 
Each digital communication line is connected, through 
its line processors, to only one switching fabric. 

The switching fabric of the present invention is used 
in a switch that switches variable-size frames of digital 
information — such as a layer-two data unit for the 
Frame Relay switching protocol, or a layer-three packet 
according to the X.25 switching protocol. 

There are different ways of implementing a switch- 
ing fabric. One way uses a shared bus to move data 
between access cards. With a shared bus, each of the 
access cards takes turns using the bus. One problem 
with this implementation is that a malfunction by one 
card may disturb the bus, rendering it unusable by the 
other access cards; such a malfunction is known as a 
single source of failure. In communications system en- 
gineering, single source failures are to be avoided, if 
practical. Another drawback to using a shared bus is that 
it causes electrical noise, which can interfere with the 
performance of the switch. 

In another implementation of a switching fabric, da- 
ta can be transmitted serially to a central switching lo- 
cation; but this implementation also suffers from having 
a potential single source of failure, namely the central 
switching location. 

In still another implementation, access cards can be 
connected with serial point-to-point links. Such a switch- 



ing fabric can use any one of several clocking schemes. 
In one scheme, the clock signal can be embedded in the 
data being switched, as is done for both Ethernet and 
FDDI LANs, but the overhead required to synchronize 

5 the receiver to the transmitted clock is excessive in re- 
lation to the volume of data being transmitted. Alterna- 
tively, a data signal with an embedded clock could be 
run continuously, avoiding the overhead for synchroniz- 
ing, but this would require a phase-locked loop for each 

io line, use more power and generate more electrical 
noise. One could also use a high-speed sampling clock 
at the destination. This is the scheme used with Univer- 
sal Asynchronous Receiver Transmitters (UARTs). 
However for performance with a throughput of approx- 

15 imately 1.2 Gbps — what the present invention pro- 
vides — a high speed sampling clock at the destination 
is impractical. 

The present invention addresses the problems of a 
single source of failure in an application for switching 

20 variable-size frames at high throughput, in the neighbor- 
hood of 1.2 Gbps. 

Although there is already a switching fabric in a te- 
lephony switch that, like the present invention, employs 
a full mesh of point-to-point links, such a telephony 

25 switch is used to switch voice traffic, and, appropriately, 
functions in a fundamentally different manner. Where 
the present invention switches data in segments (called 
buffers herein) and can use the same hardware connec- 
tion for switching part of one logical unit of information 

30 at one instant, and part of another logical unit of infor- 
mation at another instant, the full-mesh fabric in the 
voice switching application sets up and maintains a ded- 
icated connection for all segments of a logical unit of 
information. 

.35 

SUMMARY OF THE INVENTION 

The present invention is a high throughput, multiple- 
threaded switching fabric for switching variable-size 

40 frames of digital information: the switching fabric breaks 
each frame arriving at an ingress line processor, intend- 
ed for an egress line processor, into smaller units of in- 
formation called buffers herein, and transmits these 
buffers to the egress line processor. The switch system 

45 includes one or more access cards, each having ports 
for one or more digital communication lines. The switch- 
ing fabric includes some of the components of some ac- 
cess cards of the switch system, and a backplane that 
interconnects these cards. 

50 Each access card hosts one or more line proces- 
sors connected through ports to the digital communica- 
tion lines, and each line processor has an associated 
RAM on the access card. In the present invention, each 
access card hosts only one multi-line serial communi- 

55 cation controller (MSCC), a device that interfaces with 
each on-card line processor directly, through interrupts, 
and also through the line processor's associated RAM. 
Each MSCC is coupled to MSCCs on other cards 
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through the backplane, which provides a full mesh of 
serial point-to-point links for bi-directional serial commu- 
nication. The MSCC on each card is also connected 
back to itself through the backplane, this loopback al- 
lowing some built-in testing and also simplifying the de- 
sign of the switch, because with loopback a line proces- 
sor can perform the same steps to switch digital infor- 
mation to another line processor regardless of whether 
it is on the same or a different board. 

The switching fabric of the present invention com- 
prises a backplane and the MSCCs it links, where the 
MSCCs are, as described below, designed to move var- 
iable-size frames from the RAM associated with an at- 
tached ingress (source) line processor to the RAM as- 
sociated with an egress, or destination line processor 
(which may be the same line processor as the ingress 
line processor). Examples of digital communication 
lines served by the switching fabric of the present inven- 
tion include X.21, V.35, DS1, and DS3 lines. 

The switching fabric of the present invention may 
be used in a switch that includes not only a switching 
fabric for frames, but a different switching fabric for 
fixed-size cells of digital information, such as Asynchro- 
nous Transfer Mode (ATM) cells. To enable the two 
switching fabrics to exchange digital information, the 
switching fabric of the present invention serves two 
kinds of access cards: a Variable Frame Coupler (VFC) 
card and a Cell Interconnect Gateway (CIG) card. A CIG 
card connects the frame switching fabric of the present 
invention to a cell switching fabric in the same switch 
system; it is a gateway to the cell switching fabric. 

The line processors on a VFC card are called frame 
processors. They are connected directly to the digital 
communication lines between which digital information 
is being switched. The line processor on a CIG card 
(there is usually only one) is called a cell processor; it 
is also connected directly to digital communication lines, 
which lead to a cell switching fabric in the same switch 
system. 

A CIG card also includes, for each cell processor, a 
frame processor that can be the same equipment as 
used on a VFC card. The CIG card frame processor is 
not connected directly to the digital communication 
lines, and so is not a line processor, but it is coupled 
through the cell processor to the digital communication 
lines attached to the CIG card. Neither cell processors 
nor frame processors are part of the switching fabric of 
the present invention. 

The switching fabric of the present invention typi- 
cally serves several VFC cards and one or two CIG 
cards. Whether the access card is of the VFC or CIG 
type, the switching fabric includes one MSCC on each 
card, although the MSCC on a CIG card is logically con- 
figured to perform in a slightly different manner. The part 
of the overall switching fabric on a CIG card uses the 
same hardware as the part on any VFC card. The part 
of the switching fabric on a CIG card differs from the part 
on a VFC card in only one way: the MSCC on a CIG is 



logically configured to know it is being used on a CIG 
card, and to therefore store digital information in the 
RAM on the CIG card contiguously. 

The present invention provides switching at 

5 throughputs of approximately 1 .2 Gbps (0.6 Gbps max- 
imum throughput in each direction), so it is called a 
broadband switching fabric. It can be implemented at 
relatively low cost, requires relatively low power, and 
does not generate much electrical noise, compared to 

10 prior art broadband switching fabrics. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram of a switch according to 
15 the present invention. 

Fig, 2 is a diagram showing the flow of buffers from 
an ingress frame processor to an egress frame proces- 
sor. 

Fig. 3 is a block diagram of an MSCC according to 
20 the present invention. 

BEST MODE FOR CARRYING OUT THE INVENTION 

The switching fabric of the present invention is spe- 

25 cificaliy directed to switching frames, meaning herein 
variable-size packets of digital information, between an 
ingress digital communication line (a line on which a 
frame enters the switch) and an egress digital commu- 
nication line (the line on which the frame will leave the 

30 switch). In switching a frame, the switching fabric breaks 
the frame into smaller units of data, called buffers here- 
in. These buffers in turn are transported via the switch- 
ing fabric in a manner described more fully below. 

Referring now to Fig. 1, a switching fabric 20 ac- 

35 cording to the present invention is used in a switch 10 
that typically includes several access cards held in a 
chassis, each of which is either a VFC card 11 or a CIG 
card 12, all interconnected through a backplane 13. 
Each VFC card 11 has one or more VFC ports 21 con- 

40 nected to frame-bearing digital communication lines 1 4. 
Each CIG card 12 has one or more CIG ports 23 con- 
nected to cell-bearing digital communication lines 15. A 
cell as used herein refers to a fixed-size packet of digital 
information, such as a packet of digital information con- 

45 forming to the ATM protocol. A CIG card includes a cell 
processor 26 that translates cells into frames, and vice 
versa, so that the switching fabric of the present inven- 
tion switches, in fact, only frames. 

In a preferred embodiment, a switching fabric ac- 

so cording to the present invention is used by a switch that 
includes twelve access cards, which in turn can be any 
combination of VFC cards and CIG cards, although 
there are usually only one or two CIG cards served by 
the switching fabric of the present invention. Fig. 1 uses 

55 ellipses 24 and 24a to represent additional VFC cards 
and additional CIG cards, respectively. Both kinds of 
cards host at least one frame processor 17 and an as- 
sociated Random Access Memory (RAM) 18. On a CIG 
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card, there is usually only a single line processor, indi- 
cated as a cell processor 26, and one associated frame 
processor 17. 

Each frame processor 17 on a VFC card 11 is con- 
nected to one or more VFC ports 21. Each frame proc- 
essor and its RAM are interconnected through a local 
bus 28, and are both connected through a transceiver 
1 9 to the MSCC 1 6 on the card; the MSCC is part of the 
switching fabric 20. 

There is only one MSCC per VFC or CIG card : and 
it is connected through the backplane 13 by a group of 
four wires 22 (see also Fig. 3) to each card bearing an 
MSCC that is part of the switching fabric, including, in a 
loopback connection, to itself. Besides being used for 
normal switching between lines connected to the same 
card, this loopback is used to test many of the MSCC 
internal modules. In the preferred embodiment, the 
MSCC is a single microchip housing multiple hardware 
modules, which operate concurrently. 

The lone cell processor 26 on a CIG card 12 is con- 
nected to an associated RAM 18 through the local bus 
28. The lone frame processor on the CIG card is con- 
nected through the local bus 28 to the RAM 18. 

The MSCC on a CIG card is the same piece of hard- 
ware as the MSCC on a VFC card. However, because 
of how the ATM Adaptation Layer is implemented in the 
cell processor on a CIG card, all the data from a frame 
sent to a CIG card must be placed in contiguous mem- 
ory. To achieve this, the MSCC on a CIG card may use 
an input pin (not shown) to place it in CIG mode, instead 
of VFC mode. A logical '0' or 'V is applied to the input 
pin, controlled by software, to select the mode for the 
MSCC. 

A VFC card can send a frame to a CIG card to be 
transmitted as one or more ATM cells. Conversely, a 
CIG card can send data from the received cell stream 
to a VFC card to transmit as a frame according to some 
frame communication protocol such as, for example, the 
Frame Relay protocol. In both cases, however, the 
switching fabric performs the same function: moving 
buffers from one mesh point of the switching fabric to 
another. The switching fabric is not required to make 
special provision for transferring ATM cells because the 
cell processor on a CIG card performs the ATM Adap- 
tation Layer function of converting between frames and 
cells. Thus, a CIG card effectively exchanges only 
frames, not cells, with another access card tied into the 
switching fabric. 

The clocking scheme of the present invention uses 
two clock sources regulating operation of the MSCCs: 
a backplane clock is used to generate a reference signal 
25 for the clock and data information sent out on the 
backplane 13; and a local bus clock is used to generate 
a reference signal 25a for data signals transmitted on 
the local bus 28. In the preferred embodiment, the upper 
bound on frequency for the backplane clock is 80 MHz. 
The frequency is either 25 or 33 MHz for the local bus 
clock. 



In Fig. 1 , the reference signal 25 from the backplane 
clock is shown being provided to each MSCC 16 and 
16a. Fig. 3 shows this signal being provided to each of 
twelve Port Controllers 34, which interface the MSCC to 
s the backplane. In Fig. 1, there is also shown the refer- 
ence signal 25a from the local bus clock. In Fig. 3, this 
signal is seen to be provided directly to a Local Bus Con- 
. troller 33. 

Each of the twelve backplane ports has two differ- 

10 ential outputs and two differential inputs; these inputs 
and outputs are conveyed by groups of wires 22 that 
connect to PECL translators 27. The MSCC has four sin- 
gle-ended CMOS signals per port. The PECL transla- 
tors 27 convert the CMOS signals to differential signals, 

15 facilitating higher throughputs by the switching fabric. 
The two outputs consist of a clock signal and a data sig- 
nal for an MSCC on another card. The two inputs are 
clock and data signals coming from the other card. The 
backplane clock reference signal provides timing infor- 

20 mation for the output data. Each card sources its back- 
plane clock signal to all the other cards, offsetting the 
effects of timing skew. To conserve power and reduce 
crosstalk, the backplane clock signal is applied only 
when the data signal is valid. The backplane clock sig- 

25 nals are run at 80 MHz, independent of any processor 
clocks on a card. 

A Local Bus Controller (see 33 of Fig. 3) enables 
communication between an MSCC and the attached 
frame processors (those on the same card as the 

30 MSCC). It allows the frame processors to read and write 
internal MSCC registers, and the MSCC accesses the 
RAM associated with the attached frame processors 
through this controller. Each of the frame processors at- 
tached to the MSCC shares the Local Bus Controller 33 

35 for these operations. (The common bus interface is a 
Motorola 680x0 32-bit compatible data bus and control 
signals.) This controller operates in synchrony with oth- 
er internal MSCC components, using a reference at a 
frequency up to 33 MHz for clocking local bus signals. 

40 Referring now to Fig. 2, a frame, which in the pre- 

ferred embodiment of the present invention can vary in 
size up to 64 Kbytes, is received at a VFC port by an 
ingress frame processor 41, which has an associated 
RAM 49. The frame processor segments the frame as 

45 it arrives by writing it to one or more buffers, appending, 
at the beginning of each buffer, some information, that 
the switching fabric treats in the same manner as the 
received data. The maximum amount of data in a buffer 
totals 304 bytes for both received data and any append- 

50 ed header. The limit of 304 bytes in this embodiment 
arises because the MSCC uses First-In-First-Out mem- 
ories (FIFOs) to store buffers only up to that size. 

For each buffer 43, the frame processor creates a 
transmit buffer descriptor 42 used by the ingress side of 

55 the switching fabric, and adds it to a transmit chain 44, 
which is a linked list of buffer descriptors, storing the 
transmit chain in its associated RAM 49. The ingress 
card MSCC 45 loads a transmit buffer descriptor 42 and 
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corresponding buffer 43 into its internal memory (a 
transmit FIFO 37a of Fig. 3), establishes a connection 
to the destination card MSCC 46 using an intercard 
communication protocol (ICP), which is a layer two pro- 
tocol in the preferred embodiment and specifies the 
destination frame processor 48. Then, if the destination 
MSCC accepts the transfer request, the ingress MSCC 
transfers the buffer over the backplane 1 3 in a series of 
18-bit segments. 

The destination MSCC 46 can accept an incoming 
request from the source MSCC 45 if and only if a fully 
correct decoding of the request is made. The decoding 
is deemed correct only after parity checking and check- 
ing for semantic consistency of the request. A protocol 
exchange between source MSCC 45 and destination 
MSCC 46 is also required, in order to proceed with the 
data transfer. This makes each individual board virtually 
insensitive to remote hardware failures. 

Before accepting a request to receive a buffer from 
the ingress MSCC 45, the destination MSCC 46 must 
have pre-allocated a buffer descriptor from a receive 
chain 47 of the destination frame processor 48. If a re- 
ceive buffer descriptor is pre-aliocated : the destination 
MSCC 46 reads in the buffer from the backplane, writes 
it to the RAM 50 of the destination frame processor 48, 
updates the data of the receive buffer descriptor, and 
writes the updated receive buffer descriptor back to the 
receive chain. If the transfer of a buffer over the back- 
plane 13 succeeds, the destination MSCC 46 will trans- 
mit an ACK to the sending MSCC 45. After all the buffers 
comprising the frame being switched are successfully 
transferred over the backplane 1 3, the destination frame 
processor 48 sends the buffers in order, as a single 
frame entity, out onto the destination digital communi- 
cation line. 

If the receiving MSCC 46 is not ready to receive a 
buffer, or there is a problem in transmission over the 
backplane 13, the receiving MSCC notifies the ingress 
MSCC 45 not just that a transmission has failed by trans- 
mitting to it an N ACK, but also of the reason for the fail- 
ure when a buffer is successfully transferred, the 
egress MSCC also signals the ingress MSCC, in this 
case to indicate success. All of this signaling between 
frame processors is part of a more extensive error noti- 
fication system implemented in the switching fabric of 
the present invention. The system also includes a flow 
control mechanism that allows a frame processor with 
only a few empty buffers to slow the rate of data sent to it. 

A transmit buffer descriptor (BD) includes various 
items of information about its associated buffer, includ- 
ing what access card to send the frame to so it can be 
switched to its destination digital communication line. 
The ingress frame processor 17 determines the desti- 
nation frame processor based on information carried by 
the frame, and based on software tables stored in the 
switch. Each frame carries an address called a Data 
Link Connection Identifier whose value identifies a Vir- 
tual Connection. Each frame processor has software ta- 



bles stored in its RAM mapping a destination card and 
line to a Virtual Connection. The tables are downloaded 
from a control unit board, not part of the present inven- 
tion, that maintains the tables for the entire switch. 
5 The switching fabric is not responsible for removing 

transmit buffer descriptors from the transmit chain; the 
frame processor is responsible. There are various ways 
a frame processor is prompted to remove a transmit 
buffer descriptor. One way is for the source MSCC, 
io based on communication with the destination MSCC, to 
set a flag in the buffer descriptor, after a successful 
transfer, that can be polled by the frame processor. An- 
other way is for the MSCC to send an interrupt to the 
ingress frame processor; the MSCC services the inter- 
ns rupt by removing the transmit buffer descriptor from the 
transmit chain. 

In all, a transmit buffer descriptor consists of four 
kinds of information concerning the associated buffer 
and other aspects of the switching process. 

20 

1 . The Buffer Status Register contains buffer trans- 
fer information for the ingress frame processor. 
When the buffer transfer has successfully complet- 
ed or failed, the MSCC sets a Response-Ready flag 
25 and writes a Transmit-Success or Transmit-Fail flag 
in the Buffer Status Register, along with a failure 
reason code. In addition, a flow control byte sent by 
the source frame processor in a transfer acknowl- 
edgment is included if the transfer is successful. 
30 2. The Buffer Definition Register tells the MSCC 
W here the buffer is going and what size it is. It also 
tells the MSCC what procedures to follow for inter- 
rupts and CIG transfers. If the buffer descriptor is 
the last one in the transmit chain, an End-of-List 
35 (EOL) flag is set, telling the MSCC it has reached 
the end of the transmit chain. 
3. The Next Buffer Descriptor Location contains a 
pointer to the next buffer descriptor in the transmit 
chain. If the EOL flag is set, this pointer is not valid. 
40 4. The Buffer Location contains a pointer to the buff- 
er to be transmitted. 

Referring now to Fig. 3, an MSCC of a switching 
fabric according to the present invention, whether for 

45 use on a VFC card or on a CIG card, is shown in block 
diagram detail. It is built, in the present embodiment, as 
a single microchip, on which all the component modules 
operate concurrently. It includes a set of multiplexers, 
indicated as the Local Interconnect 38, that allows data 

so to be transferred between the external RAMs 18 (see 
Fig. 1) associated with the frame processors 17 and in- 
ternal receive (RX) and transmit (TX) Direct Memory Ac- 
cess (DMA) Controllers 36 and 36a. Each MSCC has 
two TX and two RX FIFOs, and two TX and two RX DMA 

55 controllers. 

Each MSCC also has four Processor Interface Con- 
trollers (PICs) 30, one for each of the maximum number 
of frame processors attached to the MSCC. Each PIC 
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is connected to each of two TX and two RX DMA con- 
trollers through the Local Interconnect 38. Each PIC is 
also connected to twelve Port Controllers 34, to a Re- 
source & Path Controller 35, to Configuration Registers 
32, and to an Interrupt Controller 31 for the same frame 
processor as the PIC. 

The FIFOs store buffers before transferring and af- 
ter receiving them over the backplane. In moving a buff- 
er from the RAM of an ingress frame processor to the 
RAM of an egress frame processor, the DMAs move 
buffers from the ingress RAM 18 (i.e., the RAM associ- 
ated with the ingress frame processor) to the TX FIFO 
37a on the ingress card, or from the RX FIFO 37 on the 
egress card to the egress RAM 18. To do this the DMAs 
read buffer descriptors. Buffer descriptors, however, are 
not transferred across the backplane, only buffers. 

On a destination VFC card, in receiving a bufferdes- 
tined for one of its frame processors, the PIC of the 
MSCC uses four internal registers it reserves for that 
frame processor. In all, on a VFC card in the preferred 
embodiment, the MSCC uses 16 registers for data re- 
ception, four for each of the four frame processors on 
the card. The MSCC on a CIG card uses internal regis- 
ters differently in receiving a frame or cell over the back- 
plane. 

Unlike the transmit chain, the receive chain is set 
up during initialization with a constant number of at least 
two fixed-size buffer descriptors. Each receive buffer 
descriptor is made up of essentially the same four kinds 
of information included in a transmit buffer descriptor: 
status, definition, next receive buffer descriptor address, 
and buffer address. The MSCC sets the 'Full/Empty' flag 
in the status field after filling a buffer, then interrupts the 
frame processor after a number of transfers, configura- 
ble by software, have been received. The 'Full/Empty' 
flag tells the frame processor there is information for it 
in the data buffer, and tells the MSCC not to reuse the 
buffer until the frame processor clears the 'Full/Empty' 
flag. 

Two TX FIFOs can simultaneously transfer buffers 
to different cards. Due to variable size buffers and des- 
tination card contention, some buffers may complete 
transfer before their predecessors in the transmit chain, 
but buffers being transferred between two cards will al- 
ways arrive in order. 

An MSCC also includes one or more Interrupt Con- 
trollers 31 , one for each frame processor, each connect- 
ed to its corresponding PIC 30. The Interrupt Controllers 
monitor interrupt conditions reported by the other MSCC 
components, asserting an interrupt signal when one or 
more conditions requiring an interrupt occur. The frame 
processor services the interrupt first by reading the in- 
terrupt register data stored in the interrupt register, one 
of the configuration registers 32, to determine the cause 
of the interrupt and then taking the appropriate action. 
The Interrupt Controller determines when the interrupt 
register has been read by the frame processor and then 
resets the register. 



The MSCC includes a Port Controller 34 for each 
of the twelve ports for the backplane connection. Each 
Port Controller 34 is also connected to each of the PICs' 
30, and all are connected to a Resource and Path Con- 

s trailer 35, which is itself also connected directly to each 
PIC 30. The Resource and Path Controller 35 controls 
the mapping of the four FIFOs 37 and 37a (two TX and 
two RX FIFOs) to the twelve Port Controllers 34. When, 
for example, requests to transfer data to the card are 

10 received on several ports at once, the Resource and 
Path Controller 35 determines which two will be allowed 
to receive, assigns a RX FIFO to each, and sets up a 
path between each RX FIFO/ Port controller pair. The 
Resource and Path Controller 35 can connect, simulta- 

15 neously, in pairs, two RX FIFOs 37 to two Port Control- 
lers 34. 

The MSCC further includes Configuration Registers 
32 accessible by the PIC and, via the Local Bus Con- 
troller 33, accessible by the frame processors on the 
20 card. 

Now, in more detail, Fig. 2 shows a frame arriving 
at a VFC port, moving from the ingress frame processor, 
through the switching fabric to the egress frame proc- 
essor, and out through the destination VFC port for the 
25 destination digital communication line. 

The ingress frame processor segments an incom- 
ing frame into one or more buffers in RAM, including in 
the buffers some information that the destination frame 
processor will need to transmit the buffers as a frame 

30 entity. Then it creates a buffer descriptor that contains 
information about the buffer, such as its size, location in 
memory, and the switch output port. The ingress frame 
processor uses information included in the frame and 
the software tables stored in the switch to determine the 

35 correct destination frame processor. When it is ready to 
have the switching fabric transfer the buffer to the des- 
tination frame processor, the ingress frame processor 
places the buffer descriptor on the transmit chain, and 
asserts a Get-Transmit flag in a configuration register 

40 for its corresponding PIC in the MSCC, which then reads 
in the contents of the buffer descriptor. 

When a TX DMA controller becomes available, the 
PIC transfers to it some of the information from the buffer 
descriptor; the information transferred includes the ad- 

45 dress of the current buffer descriptor in the RAM of the 
ingress frame processor. The TX DMA controller reads 
the buffer from the RAM of the ingress frame processor 
and places it into the TX FIFO. The Resource and Path 
Controller maps the TX DMA controller to a backplane 

50 Port Controller 34 based on the destination card identi- 
fier field. Only one of the two TX DMA controllers can 
be mapped to a particular Port Controller 34 at a time, 
but a Port Controller 34 can handle both a transmission 
and reception simultaneously. 

55 The ingress card Port Controller 34 creates a con- 
nection with the egress card Port Controller 34. In set- 
ting up this connection, the ingress Port Controller 34 
identifies the output frame processor to the destination 
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MSCC. This done, the Port Controller 34 transfers the 
buffer to the egress card. At the end of the transfer, the 
ingress Port Controller 34 sends a cyclic redundancy 
check (CRC) sum to the destination card MSCC, which 
calculates its own CRC sum. If the two sums agree, i.e. 
if the transfer was successful, the destination card 
MSCC sends the ingress card MSCC an acknowledg- 
ment signal (ACK) along with a flow control information 
byte. Otherwise, a negative acknowledgment signal 
(NACK) is returned, with a failure code identifying the 
cause of the failed transmission. 

Based on the feedback from the destination MSCC, 
the TX DMA controller writes to the transmit buffer de- 
scriptor a status identifying the success or failure of the 
transfer the flow control information, and, if appropriate, 
the failure code. The TX DMA controller may, optionally, 
send an interrupt to the ingress frame processor via the 
Interrupt Controller for that frame processor. The use of 
such an interrupt is signaled using one of the fields in 
the transmit buffer descriptor. 

On the destination card side of the switching fabric, 
before receiving a request to accept transfer of a buffer, 
the PIC corresponding to the destination frame proces- 
sor must have pre-allocated a receive buffer descriptor 
from its receive chain. If not, the destination card MSCC 
(in particular the destination card PIC) will refuse a re- 
quest to accept a buffer for that frame processor. 

By pre-allocating a buffer descriptor from the re- 
ceive chain of the destination frame processor, the PIC 
of the destination card ensures that a buffer is available. 
When a Port Controller 34 of the MSCC receives a trans- 
fer request, which indicates the destination frame proc- 
essor, the MSCC checks that the destination frame 
processor is operable and that a receive buffer descrip- 
tor is available (has been pre-allocated) in the RAM of 
that frame processor. If not, a negative acknowledgment 
(NACK) is returned to the source card. Otherwise, the 
Port Controller 34 issues a request to the destination 
Resource and Path Controller, which waits until a RX 
DMA controller is available, and then sets up a path be- 
tween the Port Controller 34 and the associated RX 
DMA controller. 

Once a transfer request has been granted, the des- 
tination PIC pre-allocates another receive buffer de- 
scriptor from the receive chain for a subsequent transfer. 

The RX DMA controller reads from the PIC some of 
the contents of the receive buffer descriptor being used 
for the transfer. The destination card then issues a Clear 
to Send (CTS) signal to the ingress card, which then 
transmits the buffer in the TX FIFO in 16-bit pieces. 

These 16-bit buffer segments could be either data, 
as when they are part of a frame being sent from one 
card to another, or code- words, according to the I CP, 
sent from one MSCC to another to coordinate the action 
of the different MSCCs of the switching fabric. To enable 
a receiving MSCC to distinguish between a buffer seg- 
ment that is data and one that contains a code-word, 
each 16-bit segment is prefaced with one bit that is '0' 



for data and '1 ' for a code-word. In addition, to signal the 
end of a segment, a final bit is affixed that is always a 
'0'. Thus, both data and code-words flow across the 
backplane from one card to another in 1 8-bit segments, 

5 counting the two added bits. 

When a buffer reaches the destination card, the 
card's Port Controller places it in the RX FIFO. From 
there, the RX DMA controller moves the buffer outside 
the switching fabric to the RAM of the destination frame 

10 processor. The RX DMA controller does not wait for the 
whole buffer to be transferred; it moves the buffer seg- 
ments as soon as memory in the destination RAM is 
available. When the entire buffer has been received and 
transferred to the destination RAM, an ACK is sent to 

is the ingress MSCC. 

The status of the received buffer is written to the 
receive buffer descriptor, including the buffer size and 
the source frame processor identifier. 

20 VFC Card to CIG Card Transfers 

The switching fabric of the present invention also 
provides for sending a variable-size frame from a VFC 
card to a CIG card. The mechanics of this digital switch- 
es ing are essentially the same as for sending a frame from 
one VFC card to another: in both cases, the switching 
fabric segments the digital information into buffers and 
sends the buffers across the backplane. There are some 
differences, however; on a CIG card, the buffers are 
30 stored in RAM contiguously. 

A VFC card sends a frame to a CIG card in buffers 
up to 304 bytes long, just as when sending frames to 
another VFC card. But in a CIG transfer, each buffer de- 
scriptor includes a flag indicating whether it is a start, 
35 middle, or end buffer in the buffer series making up the 
frame. In sending buffers to a CIG card, all of the trans- 
mit buffer descriptors are placed in order on the transmit 
chain. Multiple transmit buffer descriptors are needed 
because the frame is not stored in contiguous memory 
40 jn the RAM of the source frame processor on the VFC 
card, and because the frame may exceed 304 bytes, 
requiring multiple buffers, each needing a buffer de- 
scriptor. 

The ingress VFC frame processor waits until the en- 
45 tire frame has been received over the digital communi- 
cation line before forwarding it to the destination CIG 
card. When the MSCC on a VFC card transmits, to a 
CIG MSCC, buffers making up a frame, it sends the buff- 
ers for the entire frame before sending buffers for an- 
so other CIG transfer; it does not interleave buffers from 
two separate transmit chain entries destined for the 
same CIG card. 

In CIG mode, since in the preferred embodiment 
there is only one cell processor and associated frame 
55 processor on a CIG card, the MSCC does not need all 
four of the PICs 30 it uses on a VFC card. On a CIG 
card, the MSCC uses only two PICs: one for CIG mode 
transfers — and thus as a true processor interface con- 
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trotler — and the other for administration. The true PIC 
30 maintains twelve linked lists for received transfers, 
one for each possible source card, including itself. Each 
linked list can have buffers of a different size since it is 
configured by software. Because each source card has 
its own receive chain, each can place fragments of 
frames into a buffer without interference from other 
cards. 

In the MSCC of a CIG card, the true processor in- 
terface controller maintains four Configuration Regis- 
ters 32 for each of the twelve linked lists. The first is a 
pointer to the next memory location in RAM where the 
MSCC is writing the buffer being transferred over the 
backplane; the second is a pointer to the current receive 
buffer descriptor in the receive chain (which is in the 
RAM of the destination frame processor); the third is a 
pointer to the next receive buffer descriptor in the re- 
ceive chain; and the fourth register is a running total of 
the buffer size along with the maximum allowable size. 

When a buffer is preallocated for one of the receive 
chains, the receive buffer descriptor contents are stored 
in these registers 32. When a buffer arrives at a CIG 
card over the backplane, the four register locations cor- 
responding to the arrival port are copied to the assigned 
RX DMA. The RX DMA of the CIG MSCC writes the buff- 
er immediately to the RAM of its sole on-card frame 
processor, which it is able to do in this embodiment be- 
cause, as explained above, the egress card MSCC has 
in its internal memory the address of where to write the 
buffer. At the end of a transfer, the RX DMA controller 
points to the memory location where the following frag- 
ment is to be written. If the fragment is not the last frag- 
ment of a frame, then the memory location and the run- 
ning total of the buffer size are copied back to the Con- 
figuration Registers 32. If the fragment is the last one in 
the frame, which would be indicated by the 'End' flag in 
the buffer header, then the next receive buffer descriptor 
from the receive chain is read into the MSCC, pre-allo- 
cating a receive buffer descriptor for a future transfer. 

In this scheme, a CIG can receive large frames in 
contiguous memory, while short frames do not suffer at 
the expense of longer frames. Also, the CIG can set up 
buffer sizes appropriate to the different VFC cards of the 
switch. 

CIG Card to VFC Card Transfers 

When a CIG transfers a large frame to a VFC card, 
it places multiple buffer descriptors on the transmit chain 
so that the MSCC on the CIG card again sees only 
304-byte buffers. These buffers are usually placed in 
non-contiguous memory locations on the receiving VFC 
card; there is no requirement for these buffers to be 
stored contiguously in the RAM of the egress frame 
processor. The buffer descriptors on the receive chain 
indicate the source card (a CIG card in this case) and 
include the start, middle and end flags. Buffers from dif- 
ferent large frames do not become interleaved because 



the frames only come from one PIC on the ingress CIG 
card. The frame processor on the destination VFC card 
reassembles the buffers using the receive buffer de- 
scriptors provided by its MSCC. In providing the receive 
s buffer descriptors, the destination MSCC uses informa- 
tion communicated by the ingress MSCC, according to 
the ICR through the start, middle and end flags. 

Buffer Swapping on a CIG Card For Larger Frames 

w 

A CIG card uses a standard buffer size to receive 
frames. If a frame is larger than the standard buffer size, 
then a larger buffer is needed. The VFC card must tell 
the CIG card that it needs a larger buffer. There is a spe- 

75 cial flag in the transmit chain buffer descriptor to do this. 
The frame processor on the CIG card receives an inter- 
rupt sent by the MSCC on the VFC card, and a field in 
the receive chain buffer descriptor causes the frame 
processor to replace a standard buffer with a larger one. 

20 a three-bit field is passed with the interrupt to indicate 
the size of the larger buffer. After the buffer swap, the 
CIG card sends an interrupt to the VFC card, signaling 
that the VFC card can transfer the larger frame. The CIG 
card communicates the interrupt to the VFC card by 

25 transferring a similar buffer swap interrupt back to the 
source VFC with the three-bit field set to indicate that 
the buffer swap is complete. 

Congestion Notification 

30 

When a card runs out of buffers, it will not accept 
buffer transfers from other cards. To prevent this condi- 
tion from causing congestion in the switching fabric, a 
mechanism is implemented in the present invention by 
35 which source card frame processors control their rate of 
sending information to destination frame processors, 
depending on the status of the egress card frame proc- 
essors. 

In the present invention, the frame processor can 

40 distinguish between different levels and types of con- 
gestion. Congestion depends on the number of free 
buffers available in the RAM of the destination frame 
processor, the frame processor utilization, and other 
factors. This information is coded by the destination 

45 frame processor into a byte called the congestion field 
written to one of the Configuration Registers in its 
MSCC; it updates the field whenever its congestion level 
changes. The congestion field value is sent to a source 
card via the acknowledgment (ACK) at. the end of suc- 

so cessful transfer, and lets a sending VFC card know at 
what rate the destination VFC can receive data. When 
the congestion field indicates that the destination VFC 
card is running low on buffers, the source card scales 
back its rate of transmission, so that buffer depletion oc- 

55 curs only rarely. 

The source card frame processor can increase or 
decrease the rate of flow to a destination frame proces- 
sor by altering how often it places buffers for the desti- 
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nation card on the transmit chain. It can also discard 
frames that are indicated as low priority by a "discard 
eligible" bit according to the Frame Relay protocol. 

Configuration Registers 

. Some of the internal memory of an MSCC is ad- 
dressable by the frame processors on the same card, 
allowing those frame processors to directly read and 
write internal MSCC configuration registers 32. These 
registers are used to initialize and configure the MSCC. 
Each frame processor has its own section of MSCC ad- 
dress space. Registers which configure variables for the 
entire MSCC are contained in separate sections of the 
addressable space. All addressable registers in the 
MSCC are readable; there are no write-only registers. 
To prevent race conditions between the hardware and 
software, some MSCC registers must be read before 
their values can be overwritten by the frame processor. 

Error Protection 

In the preferred embodiment, to protect against 
transfer errors occurring between a RAM and its MSCC, 
the MSCC generates a parity bit when writing to RAM 
and checks the parity bit it generated when reading from 
RAM. Both odd and even parity are supported. 

For transfer across the backplane, protection 
against errors is provided differently for data and code- 
words. CRC protection is used for data transmitted be- 
tween MSCC devices across the back plane. An 8-byte 
CRC is generated by both the ingress and destination 
MSCC. The ingress CRC sum is sent to the destination 
MSCC, which compares it with its own CRC sum. For 
code-words sent between MSCC devices, on the other 
hand, parity protection is used. The combination of the 
protection across the backplane and protection between 
RAM and MSCC provides end-to-end protection of user 
data. 

Conclusion 

Although the invention has been shown and de- 
scribed with respect to a best mode embodiment there- 
of, it should be understood by those skilled in the art that 
the foregoing and various other changes, omissions and 
additions in the form and detail thereof, such as the 
number of access cards served by the switching fabric, 
may be made therein without departing from the spirit 
and scope of the invention. 



Claims 

1 . A switching fabric (20), for switching frames of dig- 
ital information as a sequence of buffers, each buff- 
er containing a portion of the frame to be switched, 
for use in a switch system (10) having a plurality of 



processor means for receiving and transmitting 
frames, each said processor means coupled to at 
least one bi-directional digital communication line 
(1 4, 1 5), the switch system for switching frames be- 
5 tween digital communication lines coupled to said 

processor means, the switching fabric comprising: 

a) a plurality of multi-line serial communication 
controllers (MSCCs) (16, 16a), each connected 

10 to at least one processor means, each MSCC 

having means for receiving from, and output- 
ting to, the processor means the sequence of 
buffers; and 

b) a backplane (13) connected to each MSCC 
75 through a plurality of connections (22) intercon- 
necting every MSCC of the switching fabric in 
a full mesh of bi-directional serial point-to-point 
links, the backplane for receiving from an 
MSCC the sequence of buffers and for provid- 

20 ing said sequence of buffers to a corresponding 

MSCC connected to the processor means that 
is coupled to the destination digital communi- 
cation line. 

25 2. A switching fabric as claimed in claim 1 , wherein the 
backplane interconnects at least one MSCC via a 
serial point-to-point link with itself and wherein said 
at least one MSCC includes means for receiving 
buffers from the backplane that were output by the 

30 same MSCC. 

3. A switching fabric as claimed in claim 1 , wherein the 
backplane plurality of connections forming the full 
mesh of bi-directional serial point-to-point links 

35 comprises, for each such link, a data link and a sep- 
arate clock link. 

4. A switching fabric as claimed in claim 3, wherein the 
data link consists of an incoming data signal and a 

40 separate outgoing data signal, and wherein the 
clock link consists of an incoming clock signal and 
a separate outgoing clock signal. 

5. A switching fabric as claimed in claim 3, wherein 
4 5 each MSCC uses a first reference clock signal for 

providing clock-out signals and for clocking data- 
out signals, both the clock-out signals and data-out 
signals for transmitting across the backplane. 

50 6. A switching fabric as claimed in claim 1, wherein 
each first MSCC has means to transfer flow-control 
information about each processor means connect- 
ed to the first MSCC to a second MSCC that is to 
output buffers to the first MSCC. 

55 

7. A switching fabric as claimed in claim 1, wherein 
each processor means of the switch system in- 
cludes a random access memory (RAM) in which 
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buffers are stored for transfer to and from the back- 
plane under the control of the MSCC connected to 
said processor means. 

8. A switching fabric as claimed in claim 7, wherein at 
least one MSCC has means for contiguously writing 
or reading in the RAM of the interconnected proc- 
essor means all buffers that form a single frame of 
digital information. 

9. A switching fabric as claimed in claim 1, wherein 
each first MSCC has means to update a congestion 
field associated with said first MSCC, wherein the 
congestion field is transferred via the backplane to 
a second MSCC that is to output buffers to the first 
MSCC so as to facilitate the output of said buffers 
to the first MSCC. 

10. A switching fabric as claimed in claim 1 , wherein 
each processor means has means for generating a 
buffer descriptor that contains information concern- 
ing an associated buffer and wherein the MSCC has 
means for using the buffer descriptor to facilitate the 
transfer of buffers. 

11. A switching fabric as claimed in claim 1 , wherein at 
least one processor means includes a cell proces- 
sor for transfer of ATM cells, and wherein the MSCC 
connected to said at least one processor means has 
means for controlling the storage of buffers associ- 
ated with said ATM cells in contiguous memory lo- 
cations of said at least one processor means. 

12. A switching fabric (20), for switching frames of dig- 
ital information as a sequence of buffers, for use in 
a switch system (10) having a plurality of frame 
processors (17), each with an associated RAM, and 
each frame processor (17) coupled to a plurality of 
digital communication lines (14, 15), the switching 
fabric comprising: 

a) a plurality of multi-line serial communication 
controllers (MSCCs) (16, 16a), each of which 
can serve as either an ingress MSCC or an 
egress MSCC, each attached to at least one 
frame processor and the frame processor's as- 
sociated RAM through a local bus, for receiving 
from, and outputting to, the frame processor 
through its associated RAM the sequence of 
buffers, each MSCC also connected directly to 
each attached frame processor for signaling in- 
terrupts; and 

b) a backplane (13) connected to each MSCC 
through a plurality of connections (22) intercon- 
necting every MSCC of the switching fabric in 
a full mesh of bi-directional serial point-to-point 
links, and connecting, in a loopback, each 
MSCC to itself, the backplane for receiving from 



an ingress MSCC the sequence of buffers and 
for providing said sequence of buffers to the 
corresponding egress MSCC. 

5 13. A switching fabric as claimed in claim 12, wherein 
the backplane plurality of connections forming the 
full mesh of bi-directional serial point-to-point links 
comprises, for each such link, a data link and a sep- 
arate clock link. 

70 

14. A switching fabric as claimed in claim 13, wherein 
the data link consists of an incoming data signal and 
a separate outgoing data signal, and wherein the 
clock link consists of an incoming clock signal and 

15 a separate outgoing clock signal. 

15. A switching fabric as claimed in claim 13, wherein 
each MSCC uses a first reference clock signal for 
providing clock-out signals and for clocking data- 

20 out signals, both the clock-out signals and data-out 
signals for transmitting across the backplane. 

16. A switching fabric as claimed in claim 15, wherein 
each MSCC further uses a second reference clock 

25 signal, the second reference clock signal for clock- 
ing data signals for transmitting on the local bus. 

17. A switching fabric as claimed in claim 12, wherein 
each egress MSCC signals, to any corresponding 

30 ingress MSCC, flow-control information about each 
frame processor connected to the egress MSCC, 
thereby smoothing the flow of buffers through the 
switching fabric. 

35 18. A switching fabric as claimed in claim 12, wherein 
at least one MSCC is software-controlled to store 
and read contiguously, in the RAM of an attached 
frame processor, all buffers making up a frame of 
digital information. 

40 

19. A switching fabric as claimed in claim 12, wherein 
an egress frame processor attached to an MSCC of 
the switching fabric updates a congestion field 
stored in the MSCC, wherein the congestion field is 
45 conveyed to an ingress MSCC of the switching fab- 
ric at the end of a buffer transfer, and the ingress 
MSCC notifies the ingress frame processor of re- 
ceipt of the congestion field. 

50 20, A switching fabric as claimed in claim 12, wherein 
an MSCC attached to a frame processor pre-allo- 
cates a partition of the RAM of the frame processor 
adequate to store a buffer descriptor and its asso- 
ciated buffer, before it accepts a new buffer over the 

55 backplane. 

21. A switching fabric as claimed in claim 12, wherein, 
in a transfer of a frame of digital information from 
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an ingress frame processor to an egress cell proc- 
essor with an associated RAM, of which the cell 
processor usually uses a certain size partition to 
store a frame of digital information, where the frame 
of digital information is larger than the usual parti- s 
tion of the cell processor's RAM, the MSCC at- 
tached to the ingress frame processor signals the 
MSCC attached to the egress frame processor to 
secure a partition adequate to hold the larger frame 
of digital information, and the MSCC attached to the 10 
egress frame processor signals the MSCC attached 
to the ingress frame processor to transfer the larger 
frame of digital information over.the backplane as a 
series of buffers and writes the buffers contiguously 
to the RAM of the attached egress frame processor is 
in the larger partition. 



22. A switching fabric as claimed in claim 12, wherein 
each MSCC comprises: 

20 

a) a Local Bus Controller (33) for enabling com- 
munication of buffers and buffer descriptors, via 
the local bus, between the MSCC and each at- 
tached frame processor and its associated 
RAM, responsive to a reference clock signal for 25 
clocking data signals transmitted on the local 
bus; 



and data signals arriving over the backplane, 
for providing transmitted clock and data signals 
over the backplane, both the received and 
transmitted data signals including buffers and 
code-words for managing communication, ac- 
cording to an Intercard Communication Proto- 
col, and responsive to the backplane send/re- 
ceive control signal and to the first reference 
clock signal, which provides clock-out signals 
and clocks data-out signals; 

f) a Resource and Path Controller (35), a plu- 
rality of RX FIFOs for holding buffers arriving 
from the backplane, and a plurality of TX FIFOs 
for holding buffers destined for the backplane, 
the Resource and Path Controller for logically 
connecting, based on buffer descriptor availa- 
bility signals from the Processor Interface Con- 
troller, one of said RX FIFOs or one of said TX 
FIFOs to one of said Port Controllers; 

g) a plurality of RX DMA controllers, each as- 
sociated with one of said RX FIFOs, each RX 
DMA controller for reading buffers from the as- 
sociated RX FIFO and, based on information 
conveyed as buffer descriptors from the Proc- 
essor Interface Controller, writing them, 
through the Local bus Controller to the RAM of 
one of the attached frame processors; and 

h) a plurality of TX DMA controllers, each as- 
sociated with one of said TX FIFOs, responsive 
to buffer descriptors provided by the Processor 
Interface Controller, for reading buffers from the 
RAM of one of the attached frame processors 
according to the buffer descriptor provided by 
the Processor Interface Controller, and for writ- 
ing the buffers to its associated TX FIFO; 

thereby communicating buffers in the RAM of an at- 
tached frame processor to the backplane, and com- 
municating buffers arriving over the backplane to 
the RAM of an attached frame processor. 

23. A switching fabric as claimed in claim 22, wherein 
more than one TX FIFO in an MSCC simultaneously 
transmits, across the backplane, buffers destined 
for frame processors attached to the switching fab- 
ric. 

24. A switching fabric as claimed in claim 12, wherein 
the plurality of connections (22) between the back- 
plane (13) and each MSCC is a plurality of differen- 
tial connections. 



b) Configuration Registers (32) for storing con- 
figuration information, including buffer and buff- 30 
er descriptor information, responsive to up- 
dates of the configuration information, for pro- 
viding access to the stored configuration infor- 
mation; 

35 

c) an Interrupt Controller (31), associated with 
a particular attached frame processor, respon- 
sive to interrupt register data and to signals of 
interrupt conditions, for asserting an interrupt 
signal to the particular attached frame proces- 40 
sor when an interrupt condition is signaled, and 

for de-asserting the interrupt signal when the 
interrupt is serviced by the particular attached 
frame processor; 

45 

d) a Processor Interface Controller (30) asso- 
ciated with each Interrupt Controller (31), re- 
sponsive to configuration information, for pro- 
viding interrupt conditions, for providing send/ 
receive control signals, for providing buffer de- so 
scriptor availability, and for providing buffer de- 
scriptors for buffers to be transmitted, these 
transmit buffer descriptors indicating the frame 
processor to receive the buffers to be transmit- 
ted; 55 

e) a Port Controller (34) for each MSCC of the 
switching fabric, responsive to received clock 
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ingfabric by signaling its MSCC that there is information. 
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processor coupled to the egress line. The switching fab- 
ric uses a clocking scheme that makes possible high 
throughput rates. 
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